package zisu.algorithm.algorithm.UnionFind;

public class UnionFind1 implements UnionFind {

    private int[] id;

    public UnionFind1(int size){
        id = new int[size];
        for(int i=0;i<id.length;i++){
            id[i] = i;
        }
    }

    //查看元素p 和元素q 是否同属一个集合。
    @Override
    public boolean isConnected(int p, int q) {
        return find(p) == find(q);
    }

    //合并元素p 和元素q的 所属集合
    @Override
    public void unionElements(int p ,int q) {
        int pId = find(p);
        int qId = find(q);

        if(pId == qId){
            return;
        }

        for(int i = 0;i<id.length;i++){
            if(id[i] == qId){
                id[i] = pId;
            }
        }
    }

    //查找元素p所对应的集合编号。
    private int find(int p){
        if(p<0 || p>=id.length){
            throw new IllegalArgumentException("p is out of bound");
        }
        return id[p];
    }

    @Override
    public int getSize() {
        return id.length;
    }


}
